import request from '../../utils/request'
let isSend =false //函数节流使用
// pages/search/search.js
Page({

  /**
   * 页面的初始数据
   */
  data: {
    placeholderContent:'',
    hotList:[],
    searchContent:'', //用户输入的表单项数据
    searchList:[],//模糊匹配的数据
    historyList:[]
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    this.getInitData();
  },
  // 获取本地历史记录的函数
  getSearchHistory(){
    let historyList = wx.getStorageSync('searchHistory');
    if (historyList) {
      this.setData({
        historyList
      })
    }
  },
  // 获取初始化数据
  async getInitData(){
    let placeholderData = await request('/search/default');
    let hotListData =await request('/search/hot/detail')
    this.setData({
      placeholderContent:placeholderData.data.showKeyword,
      hotList:hotListData.data
    })
  },
  // 表单项内容发生改变的回调
  handleInputChange(event){
    this.setData({
      searchContent:event.detail.value.trim()
    })
    // 函数节流
    if (isSend) {
      return 
    }
    isSend = true;
    setTimeout(() => {
      isSend =false
    }, 1000);
    // 发请求获取关键字模糊数据
    this.getSearchList()
     
  },
  //  获取搜索数据函数
  async getSearchList(){
    if (!this.data.searchContent) {
      this.setData({
        searchList:[]
      })
      return
    }
    let {searchContent, historyList} = this.data
    let searchListData =await request('/search',{keywords:searchContent, limit:10}) 
    this.setData({
      searchList:searchListData.result.songs
    })
    // 将关键字添加到历史记录当中
    if (historyList.indexOf(searchContent) !== -1) {  
      historyList.splice(historyList.indexOf(searchContent), 1)
    }

    //添加历史记录
    historyList.unshift(searchContent);
    this.setData({
      historyList
    })
    wx.setStorageSync('searchHistory', historyList)
  },
  //点击叉号清除content的回调
  clearSearchContent(){
    this.setData({
      searchContent:'',
      searchList:[]
    })
  },
  // 删除所有历史记录
  deleteSearchHistory(){
    wx.showModal({
      content:'确认删除吗？',
      success: (res) => {
        if (res.confirm) {
          this.setData({
            historyList:[]
          })
          wx.removeStorageSync('searchHistory')
        }
      }
    })
   
  },
  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady: function () {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow: function () {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide: function () {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {

  }
})